package com.youi.third.ali.dysms.util;

import com.aliyuncs.DefaultAcsClient;
import com.aliyuncs.IAcsClient;
import com.aliyuncs.dysmsapi.model.v20170525.SendSmsRequest;
import com.aliyuncs.dysmsapi.model.v20170525.SendSmsResponse;
import com.aliyuncs.http.MethodType;
import com.aliyuncs.profile.DefaultProfile;
import com.aliyuncs.profile.IClientProfile;
import com.youi.util.LogUtil;

/**
 * 阿里云发送短信工具类
 * @author erdong.Chan
 *
 */
public class SendSmsUtil {
	
	//初始化ascClient需要的几个参数
	private static final String product = "Dysmsapi";//短信API产品名称（短信产品名固定，无需修改）
	private static final String domain = "dysmsapi.aliyuncs.com";//短信API产品域名（接口地址固定，无需修改）
	//替换成你的AK
	private static final String accessKeyId = "LTAILnB0iBDodfm4";//你的accessKeyId,参考本文档步骤2
	private static final String accessKeySecret = "U2nvdiUjQ3NSu5Nxx3TTz60GpRYtks";//你的accessKeySecret，参考本文档步骤2
	
	private static final String signName="酋长外卖";
	
	/**
	 * 发送短信
	 * @param phone
	 * @param type  0为注册 1为登录 2为忘记密码
	 * @return
	 */
	public  static Boolean sendMessage(String phone,Integer type,String code){
		LogUtil.Info("短信发送 code="+code+" phone="+phone);
		try {
			//设置超时时间-可自行调整
			System.setProperty("sun.net.client.defaultConnectTimeout", "10000");
			System.setProperty("sun.net.client.defaultReadTimeout", "10000");
			//初始化ascClient,暂时不支持多region（请勿修改）
			IClientProfile profile = DefaultProfile.getProfile("cn-hangzhou", accessKeyId,
			accessKeySecret);
			DefaultProfile.addEndpoint("cn-hangzhou", "cn-hangzhou", product, domain);
			IAcsClient acsClient = new DefaultAcsClient(profile);
			//组装请求对象
			 SendSmsRequest request = new SendSmsRequest();
			 //使用post提交
			 request.setMethod(MethodType.POST);
			 //必填:待发送手机号。支持以逗号分隔的形式进行批量调用，批量上限为1000个手机号码,批量调用相对于单条调用及时性稍有延迟,验证码类型的短信推荐使用单条调用的方式
			 request.setPhoneNumbers(phone);//1500000000
			 //必填:短信签名-可在短信控制台中找到
			 request.setSignName(signName);
			 //必填:短信模板-可在短信控制台中找到
			 request.setTemplateCode(getTemplateCodeByType(type));
			 //可选:模板中的变量替换JSON串,如模板内容为"亲爱的${name},您的验证码为${code}"时,此处的值为
			 //友情提示:如果JSON中需要带换行符,请参照标准的JSON协议对换行符的要求,比如短信内容中包含\r\n的情况在JSON中需要表示成\\r\\n,否则会导致JSON在服务端解析失败
			 request.setTemplateParam("{\"code\":\""+code+"\"}");
			 //可选-上行短信扩展码(扩展码字段控制在7位或以下，无特殊需求用户请忽略此字段)
			 //request.setSmsUpExtendCode("90997");
			 //可选:outId为提供给业务方扩展字段,最终在短信回执消息中将此值带回给调用者
			 request.setOutId("yourOutId");
			 //请求失败这里会抛ClientException异常
			 SendSmsResponse sendSmsResponse = acsClient.getAcsResponse(request);
			 LogUtil.Info("sendSmsResponse.getCode()="+sendSmsResponse.getCode());
			 System.out.println(sendSmsResponse.getCode());
			 if(sendSmsResponse.getCode() != null && sendSmsResponse.getCode().equals("OK")) {
				//请求成功
				return true;
			 }
		} catch (Exception e) {
			LogUtil.Info("短信发送异常"+e.toString());
			e.printStackTrace();
			return false;
		} 
		return false;
	}
	
	/**
	 * 获取模版code
	 * @param type  0验证码
	 * @return	
	 */
	private static String getTemplateCodeByType(Integer type){
		String templateCode="";
		switch (type) {
		case 0:
			templateCode="SMS_162736490";
			break;
		}				
		return templateCode;
	}
	
	public static void main(String[] args) {
		sendMessage("18520040243", 0,"233");
	}
}
